<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8"/>
        <title>回顾Object.defineproperty方法</title>
    </head>
    <body>
        <script type="text/javascript">
            let number=18
           let person={
               name:'小慧',
               sex:'女',
               //age:18
           }

           Object.defineProperty(person,'age',{
            //    value:18,
            //    enumerable:true,  //控制属性是否可以枚举，默认值false
            //    writable:true,     //控制属性是否可以背修改
            //    configurable:true,   //控制属性是否可以被删除

            //当有人读取person的age属性时，get函数就会被调用，且返回值就是age值
            get:function(){
                console.log('有人读取get属性了')
                return number
            },

            //当有人修改person的age属性时，set函数就会被调用，且会收到修改的具体的值
            set(value){
                console.log('有人修改age属性了,且值是',value)
                number=value;
            }

           })

        //console.log(Object.keys(person))
        console.log(person)
        </script>
    </body>
</html>